merge2(x, nil) -> x
merge2(nil, y) -> y
merge2(++2(x, y), ++2(u, v)) -> ++2(x, merge2(y, ++2(u, v)))
merge2(++2(x, y), ++2(u, v)) -> ++2(u, merge2(++2(x, y), v))
↳ QTRS
↳ DependencyPairsProof
merge2(x, nil) -> x
merge2(nil, y) -> y
merge2(++2(x, y), ++2(u, v)) -> ++2(x, merge2(y, ++2(u, v)))
merge2(++2(x, y), ++2(u, v)) -> ++2(u, merge2(++2(x, y), v))
MERGE2(++2(x, y), ++2(u, v)) -> MERGE2(++2(x, y), v)
MERGE2(++2(x, y), ++2(u, v)) -> MERGE2(y, ++2(u, v))
merge2(x, nil) -> x
merge2(nil, y) -> y
merge2(++2(x, y), ++2(u, v)) -> ++2(x, merge2(y, ++2(u, v)))
merge2(++2(x, y), ++2(u, v)) -> ++2(u, merge2(++2(x, y), v))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
MERGE2(++2(x, y), ++2(u, v)) -> MERGE2(++2(x, y), v)
MERGE2(++2(x, y), ++2(u, v)) -> MERGE2(y, ++2(u, v))
merge2(x, nil) -> x
merge2(nil, y) -> y
merge2(++2(x, y), ++2(u, v)) -> ++2(x, merge2(y, ++2(u, v)))
merge2(++2(x, y), ++2(u, v)) -> ++2(u, merge2(++2(x, y), v))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ QDP
↳ QDPOrderProof
MERGE2(++2(x, y), ++2(u, v)) -> MERGE2(y, ++2(u, v))
merge2(x, nil) -> x
merge2(nil, y) -> y
merge2(++2(x, y), ++2(u, v)) -> ++2(x, merge2(y, ++2(u, v)))
merge2(++2(x, y), ++2(u, v)) -> ++2(u, merge2(++2(x, y), v))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
MERGE2(++2(x, y), ++2(u, v)) -> MERGE2(y, ++2(u, v))
POL( v ) = 0
POL( u ) = max{0, -1}
POL( ++2(x1, x2) ) = x1 + x2 + 1
POL( MERGE2(x1, x2) ) = x1
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
merge2(x, nil) -> x
merge2(nil, y) -> y
merge2(++2(x, y), ++2(u, v)) -> ++2(x, merge2(y, ++2(u, v)))
merge2(++2(x, y), ++2(u, v)) -> ++2(u, merge2(++2(x, y), v))